# Nonvolatile Memory, Dual 1024 Position Programmable Resistors 

## Preliminary Technical Data

## FEATURES

Dual, 1024 Position Resolution
25K, 250K Ohm Full Scale Resistance
Low Temperature Coefficient -- $35 \mathrm{ppm} /{ }^{\circ} \mathrm{C}$
Nonvolatile Memory Preset Maintains Wiper Settings
Wiper Settings Read Back
Linear Increment/Decrement
Log taper Increment/Decrement
SPI Compatible Serial Interface
+3 V to +5 V Single Supply or $\pm 2.5 \mathrm{~V}$ Dual Supply
26 bytes User Nonvolatile Memory for Constant Storage with Current Monitoring Configurable Function

## APPLICATIONS

SONET, SDH, ATM, Gigabit Ethernet, DWDM Laser Diode Driver Optical Supervisory Systems

## GENERAL DESCRIPTION

The ADN2850 provides dual channel, digitally controlled programmable resistors ${ }^{2}$ with resolution of 1024 positions. These devices perform the same electronic adjustment function as a mechanical rheostat. The ADN2850's versatile programming via a standard serial interface allows sixteen mode of operations and adjustment including scratch pad programming, memory storing and retrieving, increment/decrement, log taper adjustment, wiper setting readback, and extra user defined EEMEM.
In the scratch pad programming mode, a specific setting can be programmed directly to the $\mathrm{RDAC}^{2}$ register, which sets the resistance between terminals W -and-B. The RDAC register can also be loaded with a value previously stored in the EEMEM ${ }^{1}$ register. The value in the EEMEM can be changed or protected. When changes are made to the RDAC register, the value of the new setting can be saved into the EEMEM. Thereafter, such value will be transferred automatically to the RDAC register during system power ON. It is enabled by the internal preset strobe. EEMEM can also be retrieved through direct programming and external preset pin control.
Other key mode of operations include linear step increment and decrement commands such that the setting in the RDAC register can be moved UP or DOWN, one step at a time. For logarithmic changes in wiper setting, a left/right bit shift command adjusts the level in $\pm 6 \mathrm{~dB}$ steps.
The ADN2850 is available in the $5 \mathrm{~mm} \times 5 \mathrm{~mm}$ LFCSP-16 Lead Frame Chip Scale and thin TSSOP-16 packages. All parts are guaranteed to operate over the extended industrial temperature range of $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$.

FUNCTIONAL BLOCK DIAGRAM



Figure 1. $R_{W B}(D)$ vs Decimal Code

[^0]
## Nonvolatile Memory Programmable Resistors

ELECTRICAL CHARACTERISTICS 25K, 250K OHM VERSIONS $\left(V_{\text {Do }}=+3 \mathrm{~V}\right.$ to +5.5 V and,
$-40^{\circ} \mathrm{C}<\mathrm{T}_{\mathrm{A}}<+85^{\circ} \mathrm{C}$ unless otherwise noted ${ }^{12}$.)

| Parameter | Symbol | Conditions | Min | Typ ${ }^{1}$ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DC CHARACTERISTICS RHEOSTAT MODE | Specificatio | ply to all VRs |  |  |  |  |
| Resistor Differential Nonlinearity ${ }^{2}$ <br> Resistor Integral Nonlinearity ${ }^{2}$ <br> Resistance Temperature Coefficent <br> Wiper Resistance <br> Channel Resistance Matching <br> Nominal Resistor tolerance | R-DNL <br> R-INL <br> $\Delta R_{w B} / \Delta T$ <br> $\mathrm{R}_{\mathrm{w}}$ <br> $\Delta \mathrm{Rw}_{\mathrm{w}} / \mathrm{Rw}_{\text {w }}$ <br> $\Delta \mathrm{Rw}_{\mathrm{w}}$ | $R_{W B}$ <br> $\mathrm{R}_{\mathrm{WB}}$ $\begin{aligned} & \mathrm{V}_{\mathrm{DD}}=+5 \mathrm{~V}, \mathrm{I}_{\mathrm{w}}=1 \mathrm{~V} / \mathrm{RwB}_{\mathrm{w}} \\ & \mathrm{~V}_{\mathrm{DD}}=+3 \mathrm{~V}, \mathrm{I}_{\mathrm{w}}=1 \mathrm{~V} / \mathrm{R}_{\mathrm{w}} \end{aligned}$ <br> Ch 1 and 2 Rwb, $\mathrm{Dx}=3 \mathrm{FF} \mathrm{F}_{\mathrm{H}}$ $D x=3 F F_{H}$ | $-2$ <br> -4 <br> -30 | $\begin{gathered} 35 \\ 50 \\ 200 \\ 0.2 \end{gathered}$ | $+2$ <br> $+4$ <br> 100 <br> 30 | $\begin{array}{r} \mathrm{LSB} \\ \mathrm{LSB} \\ \mathrm{ppm} /{ }^{\circ} \mathrm{C} \\ \Omega \\ \Omega \\ \% \\ \% \end{array}$ |
| RESISTOR TERMINALS <br> Terminal Voltage Range ${ }^{3}$ <br> Capacitance ${ }^{4}$ Bx <br> Capacitance ${ }^{4}$ Wx <br> Common-mode Leakage Current ${ }^{5}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{W}, \mathrm{~B}} \\ & \mathrm{C}_{\mathrm{B}} \\ & \mathrm{C}_{\mathrm{W}} \\ & \mathrm{I}_{\mathrm{CM}} \end{aligned}$ | $\mathrm{f}=1 \mathrm{MHz}$, measured to GND, Code $=$ Half-scale $f=1 \mathrm{MHz}$, measured to GND, Code $=$ Half-scale $\mathrm{V}_{\mathrm{W}}=\mathrm{V}_{\mathrm{B}}=\mathrm{V}_{\mathrm{DD}} / 2$ | Vss | $\begin{gathered} 8 \\ 80 \\ 0.01 \end{gathered}$ | $V_{D D}$ $1$ | V pF pF $\mu \mathrm{A}$ |
| DIGITAL INPUTS \& OUTPUTS <br> Input Logic High <br> Input Logic Low <br> Input Logic High <br> Input Logic Low <br> Input Logic High <br> Input Logic Low <br> Output Logic High (SDO, RDY) <br> Output Logic Low <br> Input Current <br> Input Capacitance ${ }^{4}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IH}} \\ & \mathrm{~V}_{\mathrm{IL}} \\ & \mathrm{~V}_{\mathrm{H}} \\ & \mathrm{~V}_{\mathrm{IL}} \\ & \mathrm{~V}_{\mathrm{IH}} \\ & \mathrm{v}_{\mathrm{IL}} \\ & \mathrm{~V}_{\mathrm{OH}} \\ & \mathrm{~V}_{\mathrm{OL}} \\ & \mathrm{I}_{\mathrm{IL}} \\ & \mathrm{c}_{\mathrm{IL}} \end{aligned}$ |  | $\begin{aligned} & 2.4 \\ & 2.1 \\ & 2.0 \\ & 4.9 \end{aligned}$ | 5 | $\begin{aligned} & 0.8 \\ & 0.6 \\ & 0.5 \\ & 0.4 \\ & \pm 1 \end{aligned}$ | V <br> V <br> V <br> V <br> V <br> V <br> V <br> V <br> V <br> A <br> pF |
| POWER SUPPLIES <br> Single-Supply Power Range <br> Dual-Supply Power Range <br> Positive Supply Current <br> Programming Mode Current <br> Read Mode Current <br> Negative Supply Current <br> Power Dissipation ${ }^{6}$ <br> Power Supply Sensitivity | $V_{D D}$ <br> Vdo/vss <br> $I_{D D}$ <br> $I_{D D(P G)}$ <br> $I_{\text {DD(READ) }}$ <br> $\mathrm{I}_{\mathrm{ss}}$ <br> $\mathrm{P}_{\mathrm{DISS}}$ <br> PSS | $V_{s s}=0 \mathrm{~V}$ $\begin{aligned} & V_{I H}=V_{D D} \text { or } V_{I L}=G N D \\ & V_{I H}=V_{D D} \text { or } V_{I L}=G N D \\ & V_{I H}=V_{D D} \text { or } V_{I L}=G N D \\ & V_{I H}=V_{D D} \text { or } V_{I L}=G N D, V_{D D}=2.5 \mathrm{~V}, V_{S S}=-2.5 \mathrm{~V} \\ & V_{I H}=V_{D D} \text { or } V_{I L}=G N D \\ & \Delta V_{D D}=+5 V \pm 10 \% \end{aligned}$ | $\begin{gathered} 3.0 \\ \pm 2.25 \end{gathered}$ | $\begin{gathered} 2 \\ 35 \\ 3 \\ 2 \\ 6 \\ 0.002 \end{gathered}$ | $\begin{gathered} 5.5 \\ \pm 2.75 \\ 20 \\ \\ 20 \\ 110 \\ 0.01 \end{gathered}$ | $V$ V $\mu \mathrm{~A}$ mA mA $\mu \mathrm{~A}$ $\mu \mathrm{~W}$ $\%$ |
| CURRENT MONITOR Terminals <br> Current Sink at $\mathrm{V}_{1}{ }^{7}$ <br> Current Sink at $\mathrm{V}_{2}$ | $\begin{array}{\|l\|l} I_{1} \\ I_{2} \end{array}$ |  | 0.0001 |  | $\begin{aligned} & 10 \\ & 10 \end{aligned}$ |  |
| DYNAMIC CHARACTERISTICS4,8 <br> Resistor Noise Spectral Density <br> Analog Crosstalk ( $\mathrm{C}_{w_{1}} / \mathrm{C}_{\text {w }}$ ) | $\begin{array}{\|l} \mathrm{e}_{\mathrm{N}, \mathrm{WB}} \\ \mathrm{C}_{\mathrm{T}} \end{array}$ | $R_{\text {WB_FS }}=25 \mathrm{~K} \Omega / 250 \mathrm{~K} \Omega, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ <br> $\mathrm{V}_{\mathrm{B} 1}=\mathrm{V}_{\mathrm{B} 2}=0 \mathrm{~V}$, Measured $\mathrm{V}_{\mathrm{W} 1}$ with <br> $V_{\mathrm{w} 2}=100 \mathrm{mV} \mathrm{p}-\mathrm{p} @ \mathrm{f}=100 \mathrm{kHz}$, Code $_{1,2}=200 \mathrm{H}$ |  | $\begin{gathered} 20 / 64 \\ -65 \end{gathered}$ |  | $n V V H z$ <br> dB |

NOTES: See bottom of table next page.

## Nonvolatile Memory Programmable Resistors

ELECTRICAL CHARACTERISTICS 25K , 250K OHM VERSIONS $\left(\mathrm{V}_{\mathrm{DD}}=+3 \mathrm{~V}\right.$ to +5.5 V and, $-40^{\circ} \mathrm{C}<\mathrm{T}_{\mathrm{A}}<+85^{\circ} \mathrm{C}$ unless otherwise noted ${ }^{12}$.)

| Parameter | Symbol | Conditions | Min | Typ ${ }^{1}$ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| INTERFACE TIMING CHARACTERISTICS applies to all parts(Notes 4, 9) |  |  |  |  |  |  |
| Clock Cycle Time (tcyc) | $\mathrm{t}_{1}$ |  | 20 |  |  | ns |
| CS Setup Time | $\mathrm{t}_{2}$ |  | 10 |  |  | ns |
| CLK Shutdown Time to CS rise | $\mathrm{t}_{3}$ |  | 1 |  |  | tcyc |
| Input Clock Pulse Width | $t_{4}, t_{5}$ | Clock level high or low | 10 |  |  | ns |
| Data Setup Time | $\mathrm{t}_{6}$ | From Positive CLK transition | 5 |  |  | ns |
| Data Hold Time | $\mathrm{t}_{7}$ | From Positive CLK transition | 5 |  |  | ns |
| CS to SDO - SPI line acquire | $\mathrm{t}_{8}$ |  |  | 6 | 40 | ns |
| CS to SDO - SPI line release | $t 9$ |  |  | 34 | 100 | ns |
| CLK to SDO Propagation Delay ${ }^{10}$ | $\mathrm{t}_{10}$ | $\mathrm{R}_{\mathrm{P}}=2.2 \mathrm{~K} \Omega, \mathrm{C}_{\mathrm{L}}<20 \mathrm{pF}$ |  | 34 | 100 | ns |
| CLK to SDO Data Hold Time | $\mathrm{t}_{11}$ | $\mathrm{R}_{\mathrm{P}}=2.2 \mathrm{~K} \Omega, \mathrm{C}_{\mathrm{L}}<20 \mathrm{pF}$ | 0 |  |  | ns |
| CS High Pulse Width | $\mathrm{t}_{12}$ |  | 10 |  |  | ns |
| CS High to CS High | $\mathrm{t}_{13}$ |  | 4 |  |  | tevc |
| RDY Rise to CS Fall | $\mathrm{t}_{14}$ |  | 0 | 1 |  | $\mu \mathrm{s}$ |
| CS Rise to RDY fall time | t 15 |  |  | 0.11 |  | ms |
| Read/Store to Nonvolatile EEMEM ${ }^{11}$ | t 16 | Applies to Command $2 \mathrm{H}, 3 \mathrm{H}, 9^{\mathrm{H}}$ |  |  | 25 | ms |
| CS Rise to Clock Edge Setup | $\mathrm{t}_{17}$ |  | 10 |  |  | ns |
| Preset Pulse Width (Asynchronous) | tprw | Not shown in timing diagram | 50 |  |  | ns |
| Preset Response Time to RDY High | tpresp | PR pulsed low to refreshed wiper positions |  | 70 |  | us |
| FLASH/EE MEMORY RELIABILITY ${ }^{13}$ |  |  |  |  |  |  |
| Endurance |  |  | 100,000 |  |  | Cycles |
| Data Retention ${ }^{14}$ |  |  |  | 100 |  | Years |

## NOTES:

1. Typicals represent average readings at $+25^{\circ} \mathrm{C}$ and $\mathrm{V}_{D D}=+5 \mathrm{~V}$.
2. Resistor position nonlinearity error R-INL is the deviation from an ideal value measured between the maximum resistance and the minimum resistance wiper positions. R-DNL measures the relative step change from ideal between successive tap positions. $I_{w} \sim 50 \mathrm{uA}$ for $V_{D D}=+2.7 \mathrm{~V}$ and $\mathrm{I}_{\mathrm{w}} \sim 400 \mathrm{uA}$ for $V_{D D}=+5 \mathrm{~V}$. See test circuit figure xxxx
3. Resistor terminals $\mathrm{W}, \mathrm{B}$ have no limitations on polarity with respect to each other.
4. Guaranteed by design and not subject to production test.
5. Common mode leakage current is a measure of the DC leakage from any terminal B and W to a common mode bias level of $\mathrm{V}_{\mathrm{DD}} / 2$.
6. PoIss is calculated from ( $\left(\mathrm{loD} \times \mathrm{VDD}_{\mathrm{DD}}\right)+\left(\mathrm{ISS}_{\mathrm{SS}} \times \mathrm{V}_{\mathrm{SS}}\right)$
7. Applies to Photo Diode of Optical Receiver
8. All dynamic characteristics use $\mathrm{V}_{\mathrm{DD}}=+5 \mathrm{~V}$ and $\mathrm{V}_{S S}=0 \mathrm{~V}$
9. See timing diagram for location of measured values. All input control voltages are specified with $\mathrm{t}_{\mathrm{R}}=\mathrm{t}_{\mathrm{t}}=2.5 \mathrm{~ns}(10 \%$ to $90 \%$ of 3 V$)$ and timed from a voltage level of 1.5 V . Switching characteristics are measured using both $\mathrm{V}_{\mathrm{DD}}=+3 \mathrm{~V}$ and +5 V .
10. Propagation delay depends on value of $V_{D D}$, $R_{\text {pulL_up, }}$ and $C_{L}$ see applications text.
11. RDY pin low only for commands $2,3,8,9,10$, and $\operatorname{PR}$ hardware pulse: CMD_8~1ms; CMD_9,10 $\sim 0.1 \mathrm{~ms} ; C M D \_2,3 \sim 20 \mathrm{~ms}$. Device operation at $T_{A}=-40^{\circ} \mathrm{C}$ \& VDD $<+3 \mathrm{~V}$ extends the save time to 35 ms .
12. Parts can be operated at +2.7 V single supply, except from $0^{\circ} \mathrm{C}$ to $-40^{\circ} \mathrm{C}$ where minimum +3 V is needed
13. The ADN2850 contains 16,000 transistors. Die size: 100 mil $\times 150$ mil, 10,500 sq. mil.
14. Retention lifetime equivalent at junction temperature $\left(\mathrm{T}_{\mathrm{J}}\right)=55^{\circ} \mathrm{C}$ as per JEDEC Std. 22 , Method A 117 . Retention lifetime based on an activation energy of 0.6 eV will derate with junction temperature as shown in Figure xxx in the Flash/EE Memory description section of this data sheet.

Specifications Subject to Change without Notice

## Timing Diagram



* Note: Not defined, but normally LSB of character previously transmitted. The CPOL=1 micro controller command aligns the incoming data to the positive edge of the clock.

* Note: Not defined, but normally MSB of character just received. The CPOL=0 micro controller command aligns the incoming data to the positive edge of the clock.

Figure $2 B$. $C P H A=0$ Timing Diagram

## PRELIMINARY TECHNICAL DATA

Nonvolatile Memory Programmable Resistors

| Absolute Maximum Rating ${ }^{1}\left(\mathrm{~T}_{\mathrm{A}}=+25^{\circ} \mathrm{C}\right.$, unless otherwise noted) |
| :---: |
| $\mathrm{V}_{\mathrm{DD}}$ to GND...................................................-0.3V, +7 V |
| $\mathrm{V}_{\text {SS }}$ to GND .................................................... $+0.3 \mathrm{~V},-7 \mathrm{~V}$ |
|  |
| $\mathrm{V}_{\mathrm{B}}, \mathrm{V}_{\mathrm{W}}$ to GND............................... $\mathrm{V}_{\text {SS }}-0.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{DD}}+0.3 \mathrm{~V}$ |
|  |
| Intermittent ${ }^{2}$............................................ $\pm 20 \mathrm{~mA}$ |
| Continuous............................................ $\pm 1.3 \mathrm{~mA}$ |

Digital Inputs \& Output Voltage to GND..... $-0.3 \mathrm{~V}, \mathrm{~V}_{\mathrm{DD}}+0.3 \mathrm{~V}$
Operating Temperature Range ${ }^{3}$........................ $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
Maximum Junction Temperature ( $\mathrm{T}_{\mathrm{J}}$ MAX)................... $+150^{\circ} \mathrm{C}$
Storage Temperature. $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
Lead Temperature, Soldering ${ }^{4}$

> Vapor Phase (60 sec) ................................................................................ ${ }^{\circ} \mathrm{C}$
> Infrared $(15 \mathrm{sec}) . . . . . . . . . . . .$.

Thermal Resistance Junction-to-Ambient $\theta_{\mathrm{JA}}$,
LFCSP-16 $\qquad$ $35^{\circ} \mathrm{C} / \mathrm{W}$

TSSOP-16 $\qquad$ $150^{\circ} \mathrm{C} / \mathrm{W}$
Thermal Resistance Junction-to-Case $\boldsymbol{\theta}_{\mathrm{JC}}$,
$\qquad$
TSSOP-16 $\qquad$ $28^{\circ} \mathrm{C} / \mathrm{W}$

$$
\text { Package Power Dissipation }=\left(\mathrm{T}_{\mathrm{J}} \mathrm{MAX}-\mathrm{T}_{\mathrm{A}}\right) / \theta_{\mathrm{JA}}
$$

## NOTES

1. Stresses above those listed under Absolute Maximum Ratings may cause permanent damage to the device. This is a stress rating; functional operation of the device at these or any other conditions above those listed in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.
2. Maximum terminal current is bounded by the maximum current handling of the switches, maximum power dissipation of the package, and maximum applied voltage across any two of the B, and W terminals at a given resistance.
3. Includes programming of Nonvolatile memory
4. Applicable to TSSOP-16 only. For LFCSP-16, please consult factory for detail

Ordering Guide

| Model | $\begin{gathered} \mathbf{R}_{\mathrm{WB}} \\ (\mathbf{k ~ O h m}) \end{gathered}$ | $\begin{gathered} \text { RDNL } \\ \text { (LSB) } \end{gathered}$ | $\begin{aligned} & \text { RINL } \\ & \text { (LSB) } \end{aligned}$ | Temp Range | Package Description | Package Option | Top Mark* |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ADN2850ACP25 | 25 | $\pm 2$ | $\pm 4$ | $-40 /+85^{\circ} \mathrm{C}$ | LFCSP-16 | CP-16 | ACP25 |
| ADN2850ACP25-RL7 | 25 | $\pm 2$ | $\pm 4$ | $-40 /+85^{\circ} \mathrm{C}$ | $\begin{gathered} \text { LFCSP-16 } \\ \text { 1500 Pieces } \\ 7 " \text { Reel } \end{gathered}$ | CP-16 | ACP25 |
| ADN2850ACP250 | 250 | $\pm 2$ | $\pm 4$ | $-40 /+85^{\circ} \mathrm{C}$ | LFCSP-16 | CP-16 | ACP250 |
| ADN2850ACP250-RL7 | 250 | $\pm 2$ | $\pm 4$ | $-40 /+85^{\circ} \mathrm{C}$ | $\begin{gathered} \text { LFCSP-16 } \\ \text { 1500 Pieces } \\ 7 " \text { Reel } \end{gathered}$ | CP-16 | ACP250 |
| ADN2850ARU25 | 25 | $\pm 2$ | $\pm 4$ | $-40 /+85^{\circ} \mathrm{C}$ | TSSOP-16 | RU-16 | ARU25 |
| ADN2850ARU25-REEL7 | 25 | $\pm 2$ | $\pm 4$ | $-40 /+85^{\circ} \mathrm{C}$ | $\begin{gathered} \hline \text { TSSOP-16 } \\ 1000 \text { Pieces } \\ 7 " \text { Reel } \\ \hline \end{gathered}$ | RU-16 | ARU25 |

* Line 1 contains ADI logo symbol and date code YYWW, line 2 contains product number ADN2850, line 3 branding containing differentiating detail by part type, line 4 contains lot number.


## CAUTION

ESD (electrostatic discharge) sensitive device. Electrostatic charges as high as 4000 V readily accumulate on the human body and test equipment and can discharge without detection. Although the ADN2850 features proprietary ESD protection circuitry, permanent damage may occur on devices subjected to high-energy electrostatic discharges. Therefore, proper ESD precautions are recommended
 to avoid performance degradation or loss of functionality.

ADN2850ACP PIN CONFIGURATION


ADN2850ACP PIN DESCRIPTION

| \# | Name | Description |
| :---: | :---: | :---: |
| 1 | SDO | Serial Data Output Pin. Open Drain Output requires external pull-up resistor. Commands 9 and 10 activate the SDO output. See Instruction operation Truth Table. Table 2. Other commands shift out the previously loaded SDI bit pattern delayed by 24 clock pulses. This allows daisy-chain operation of multiple packages. |
| 2 | GND | Ground pin, logic ground reference |
| 3 | $\mathrm{V}_{\text {ss }}$ | Negative Supply. Connect to zero volts for single supply applications. |
| 4 | $\mathrm{V}_{1}$ | Log Output Voltage 1 generated from internal diode configured transistor |
| 5 | W1 | Wiper terminal of RDAC1. $\operatorname{ADDR}(\mathrm{RDAC} 1)=0_{\mathrm{H}}$. |
| 6 | B1 | B terminal of RDAC1 |
| 7 | B2 | B terminal of RDAC2. |
| 8 | W2 | Wiper terminal of RDAC2. $\operatorname{ADDR}(\operatorname{RDAC} 2)=1_{\mathrm{H}}$. |
| 9 | $\mathrm{V}_{2}$ | Log Output Voltage 2 generated from internal diode configured transistor |
| 10 | $\mathrm{V}_{\mathrm{DD}}$ | Positive Power Supply Pin. |
| 11 | WP | Write Protect Pin. When active low, WP prevents any changes to the present register contents, except PR and cmd 1 and 8 will refresh the RDAC register from EEMEM. |
| 12 | PR | Hardware over ride preset pin. Refreshes the scratch pad register with current contents of the EEMEM register. Factory default loads midscale $512_{10}$ until EEMEM loaded with a new value by the user ( PR is activated at the logic high transition). |
| 13 | CS | Serial Register chip select active low. Serial register operation takes place when CS returns to logic high. |
| 14 | RDY | Ready. Active-high open drain output. Identifies completion of commands $2,3,8,9,10$, and PR. |
| 15 | CLK | Serial Input Register clock pin. Shifts in one bit at a time on positive clock edges. |
| 16 | SDI | Serial Data Input Pin. Shifts in one bit at a time on positive clock CLK edges. MSB loaded first. |

ADN2850ARU PIN CONFIGURATION


## ADN2850ARU PIN DESCRIPTION

| \# | Name |  |
| :---: | :--- | :--- |
| 1 | CLK | Description <br> 2 |

## PRELIMINARY TECHNICAL DATA

## Nonvolatile Memory Programmable Resistors

Table 1. ADN2850 24-bit Serial Data Word

|  | MSB |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | LSB |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RDAC | C3 | C2 | C1 | C0 | 0 | 0 | 0 | A0 | X | X | X | X | X | X | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
| EEMEM | C3 | C2 | C1 | CO | A3 | A2 | A1 | A0 | $\begin{aligned} & \hline \mathrm{D} \\ & 15 \end{aligned}$ | $\begin{aligned} & \hline \text { D } \\ & 14 \end{aligned}$ | $\begin{aligned} & \hline \mathrm{D} \\ & 13 \end{aligned}$ | $\begin{aligned} & \hline \mathrm{D} \\ & 12 \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline \mathrm{D} \\ & 11 \end{aligned}$ | $\begin{aligned} & \hline \mathrm{D} \\ & 10 \\ & \hline \end{aligned}$ | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |

Command bits are C0 to C3. Address bits are A3-A0. Data bits D0 to D9 are applicable to RDAC whereas D0 to D15 are applicable to EEMEM. Command instruction codes are defined in table 2.

Table 2. ADN2850 Instruction/Operation Truth Table ${ }^{\text {a,b,d }}$


NOTES:
a) The SDO output shifts-out the last 24 -bits of data clocked into the serial register for daisy chain operation. Exception, following Instruction \#9 or \#10 the selected internal register data will be present in data byte 0 \& 1. Instructions following \#9 \& \#10 must be a full 24 -bit data word to completely clock out the contents of the serial register.
b) The RDAC register is a volatile scratch pad register that is refreshed at power ON from the corresponding non-volatile EEMEM register.
c) The increment, decrement and shift commands ignore the contents of the shift register Data Bytes 0 and 1 .
d) Execution of the above Operations takes place when the CS strobe returns to logic high.
e) Instruction \#3 write two data bytes to EEMEM. But in the cases of addresses 0 and 1 , only the last 10 bits are valid for wiper position setting.

## OPERATIONAL OVERVIEW

The ADN2850 programmable resistor is designed to operate as a true variable resistor. The resistor wiper position is determined by the RDAC register contents. The RDAC register acts as a scratch pad register which allows unlimited changes of resistance settings. The scratch pad register can be programmed with any position setting using the standard SPI serial interface by loading the 24 -bit data word. The format of the data word is that the first 4 bits are instructions, the following 4 bits are Addresses, and the last 16 bits are data. Once a specific value is set, this value can be saved into a corresponding EEMEM register. During subsequent power up, the wiper setting will automatically be loaded at that value. Saving data to the EEMEM takes about 25 ms , and consumes approximately 20 mA . During this time the shift register is locked preventing any changes from taking place. The RDY pin indicates the completion of this EEMEM saving process. There are also 13, 2 bytes each of user defined data that can be stored in EEMEM.

## OPERATION DETAIL

There are sixteen instructions which faciliates users' programming needs. Refer to Table 2, the instructions are:
0. Do Nothing

1. Restore EEMEM setting to RDAC
2. Save RDAC setting to EEMEM
3. Save RDAC setting or user data to EEMEM
4. Decrement 6dB
5. Decrement all 6 dB
6. Decrement one step
7. Decrement all one step
8. Reset EEMEM setting to RDAC
9. Read EEMEM to SDO
10. Read Wiper Setting to SDO
11. Write data to RDAC
12. Increment 6 dB
13. Increment all 6 dB
14. Increment one step
15. Increment all one step

## Scratch Pad and EEMEM Programming

The basic mode of setting the programmable resistor wiper position (programming the scratch pad register) is accomplished by loading the serial data input register with the instruction \#11, the correponding address, and the data. When the desired wiper position is determined, the user can load the serial data input register with the instruction \#2, which stores the setting into the corresponding EEMEM register. After 25 ms the wiper position will be stored in the corresponding EEMEM location. If desired, this value can be changed by users in the future or users can set the write-protect to permanently protect the data. Figure 3 provides a programming example listing the sequence of serial data input (SDI) words and the corresponding serial data output (SDO) in hexadecimal format.

| SDI | $\underline{\text { SDO }}$ | $\underline{\text { Action }}$ |
| :--- | :--- | :--- |
| $\mathrm{B} 00100_{\mathrm{H}}$ | $\mathrm{XXXXXX}_{\mathrm{H}}$ | Loads data $100_{\mathrm{H}}$ into RDAC1 register, Wiper <br> W1 moves to $1 / 4$ full-scale position |
| $20 \mathrm{xxxx}_{\mathrm{H}}$ | ${\mathrm{B} 00100_{\mathrm{H}}}$ | Saves copy of RDAC1 register contents into <br> corresponding EEMEM1 register. |
| $\mathrm{B} 10200_{\mathrm{H}}$ | $20 \mathrm{xxxx}_{\mathrm{H}}$ | Loads 200 <br> W2 moves to $1 / 2$ full-scale position |
| $21 \mathrm{Xxxx}_{\mathrm{H}}$ | $\mathrm{B} 10200_{\mathrm{H}}$ | Saves copy of RDAC2 register contents into <br> corresponding EEMEM2 register. |

Figure 3. Set and Save two channels of programmable resistors with independent datas.

At system power ON, the scratch pad register is refreshed with the value previously saved in the corresponding EEMEM register. The factory preset EEMEM value is midscale. The scratch pad register can also be loaded with the contents of the EEMEM register in three different ways. Executing instruction \#1 retrieves the corresponding EEMEM value, executing instruction \#8 resets both channels EEMEM values, and pulsing the PR pin also refreshs both EEMEM settings. Operate the PR function however requires a complete pulse signal. When PR goes low, the internal logic sets the wiper at midscale. The EEMEM value will not be loaded until PR returns to high.

## E2MEM Protection

The write-protect (WP) pin provides a hardware EEMEM protection feature which disables any changes of the current content in the scratch pad register at all except commands 1,8 , and PR. Executing these three events cause the EEMEM values restored to the scratch pad registers.

## Linear Increment and Decrement Commands

The increment and decrement commands (\#14, \#15, \#6, \#7) are useful for linear step adjustment applications. These commands simplify micro controller software coding by allowing the controller to just send an increment or decrement command to the device. The adjustment can be individual or ganged arrangement. For increment command, executing instruction \#14 will automatically move the wiper to the next resistance segment position. The master increment instruction $\# 15$ will move all resistor wipers up by one position.

## Logarithmic Taper Mode Adjustment ( $\pm 6 \mathrm{~dB} /$ step)

Four programming instructions produce logarithmic taper increment and decrement wiper position control by either individual or ganged arrangement. These settings are activated by the 6 dB increment and 6 dB decrement instructions \#12 \& \#13 and \#4 \& \#5 respectively. For example, starting at zero scale, executing eleven times of the increment instruction \#12 will move the wiper in +6B per step from the $0 \%$ of the full scale $\mathrm{R}_{\mathrm{WB}}$ to the full scale $\mathrm{R}_{\mathrm{WB}}$. The +6 dB increment instruction doubles the value of the RDAC register contents each time the command is executed. When the wiper position is near the maximum setting, the last +6 dB increment instruction will cause the wiper to go to the full-scale 1023 code position. Further +6 dB per increment instruction will no longer change the wiper position beyond its full scale.

## PRELIMINARY TECHNICAL DATA

## Nonvolatile Memory Programmable Resistors

6 dB step increment and decrement are achieved by shifting the bit internally to the left and right respectively. The following information explains the nonideal $\pm 6 \mathrm{~dB}$ step adjustment at certain conditions. Table 3 illustrates the operation of the shifting function on the individual RDAC register data bits. Each line going down the table represents a successive shift operation. Note that the left shift \#12 \& \#13 commands were modified such that if the data in the RDAC register is equal to zero, and the data is left shifted, the RDAC register is then set to code 1 . Similary, if the data in the RDAC register is greater than or equal to mid-scale, and the data is left shifted, then the data in the RDAC register is automatically set to full-scale. This makes the left shift function as ideal logarithmic adjustment as is possible.
The right shift \#4 \& \#5 commands will be ideal only if the LSB is zero (i.e. ideal logarithmic - no error). If the LSB is a one then the right shift function generates a linear half LSB error, which translates to a numbers of bits dependent logarithmic error as shown in Figure 4. The plot shows the error of the odd numbers of bits for ADN2850.

|  | Left Shift | Right Shift | $\begin{gathered} \text { Right } \\ \text { Shift } \\ (-6 \mathrm{~dB} / \text { step }) \end{gathered}$ |
| :---: | :---: | :---: | :---: |
|  | 0000000000 | 1111111111 |  |
|  | 0000000001 | 0111111111 |  |
|  | 0000000010 | 0011111111 |  |
|  | 0000000100 | 0001111111 |  |
| Left | 0000001000 | 0000111111 |  |
| Shift | 0000010000 | 0000011111 |  |
| (+6dB/step) | 0000100000 | 0000001111 |  |
|  | 0001000000 | 0000000111 |  |
|  | 0010000000 | 0000000011 |  |
|  | 0100000000 | 0000000001 |  |
|  | 1000000000 | 0000000000 |  |
|  | 1111111111 | 0000000000 |  |
| $\nabla$ | 1111111111 | 0000000000 |  |

Table 3. Detail Left and Right Shift functions for 6 dB step increment and decrement.

Actual conformance to a logarithmic curve between the data contents in the RDAC register and the wiper position for each Right Shift \#4 \& \#5 command execution contains an error only for odd numbers of bits. Even numbers of bits are ideal. The graph in Figure 4 shows plots of Log_Error [i.e. $20 * \log _{10}$ (error/code)] ADN2850. For example, code 3
Log_Error=20* $\log _{10}(0.5 / 3)=-15.56 \mathrm{~dB}$, which is the worst case. The plot of Log_Error is more significant at the lower codes.


Figure 4. Plot of Log_Error Conformance for Odd Numbers of Bits Only (Even Numbers of Bits are ideal)

## Using Additional internal Nonvolatile EEMEM

The ADN2850 contains additional internal user storage registers (EEMEM) for saving constants and other 16-bit data. Table 4 provides an address map of the internal storage registers shown in the functional block diagram as EEMEM1, EEMEM2, and 26 bytes of USER EEMEM.

| Address | EEMEM For |
| :---: | :---: |
| 0000 | RDAC1 $^{\mathrm{a}, \mathrm{c}}$ |
| 0001 | RDAC $2 ~^{\text {a }}$ |
| 0010 | USER $1^{\mathrm{b}}$ |
| 0011 | USER2 |
| $:$ | $:$ |
| 1110 | USER13 |
| 1111 | Factory Reserved |

Table 4: EEMEM Address Map
NOTES:
a) RDAC data stored in EEMEM locations are transferred to their
corresponding RDAC REGISTER at Power ON, or when instructions Inst\#1, \#8, and PR are executed.
b) USER <data> are internal nonvolatile EEMEM registers available to store and retrieve constants and other 16-bit information using Inst\#3 and Inst\#9 respectively.
c) Execution of instruction \#1 leaves the device in the Read Mode power consumption state. After the last Instruction \#1 is executed, the user should perform a NOP, Instruction \#0 to return the device to the low power idling state.

## Daisy Chain Operation

The serial data output pin (SDO) can be used to readout the content of the wiper settings or EEMEM values under instructions 10 and 9 respectively. If these instructions are not used, SDO can be used for daisy chaining multiple devices for simultaneous operations, see Figure 5. SDO pin contains an open drain N-Ch FET and requires a pull-up resistor if SDO function is used. Users need to tie the SDO pin of one package to the SDI pin of the next package. Users may need to increase the clock period because the pull-up resistor and the capacitive loading at the SDO-SDI interface may induce time delay to the subsequent devices, see Figure 5. If two ADN2850 are daisy chained, this requires total 48 bits of data. The first 24 bits (formatted 4-bit instruction, 4-bit address, and 16-bit data) goes to U 2 and the second 24 bits with the same format goes to U 1 . The CS should be kept low until all 48 bits are clocked into their respective serial registers. The CS is then pulled high to complete the operation.


Figure 5. Daisy Chain Configuration

## DIGITAL INPUT/OUTPUT CONFIGURATION

All digital inputs are ESD protected. Digital inputs are high impedance and can be driven directly from most digital sources. For PR and WP, which are active at logic low, should be biased to $V_{D D}$ if they are not used. There are no internal pull-up resistors on any digital input pin. As a result, pull-up resistors are needed if these functions are used.
For SDO and RDY pins, they are open drain digital outputs. Similarly, pull-up resistors are needed if these functions are used. To optimize the speed and power trade off, use $2.2 \mathrm{k} \Omega$ pull-up resistors.


Figure 6. Equivalent Digital Input-Output Logic
The equivalent serial data input and output logic is shown in figure 6 . The open drain output SDO is disabled whenever chip select CS is logic high. The SPI interface can be used in two slave modes $\mathrm{CPHA}=1, \mathrm{CPOL}=1$ and $\mathrm{CPHA}=0, \mathrm{CPOL}=0$..
ESD protection of the digital inputs is shown in figures 7A \& 7B.


Figure 7A. Equivalent ESD Digital Input Protection

## PRELIMINARY TECHNICAL DATA

## Nonvolatile Memory Programmable Resistors

## RDAC STRUCTURE

The RDAC contains a string of equal resistor segments, with an array of analog switches, that act as the wiper connection. The number of positions is the resolution of the device. The ADN2850 has 1024 connection points allowing it to provide better than $0.1 \%$ set-ability resolution. Figure 8 shows an equivalent structure of the connections between the two terminals that make up one channel of the RDAC. The $\mathrm{SW}_{\mathrm{B}}$ will always be ON, while one of the switches $\operatorname{SW}(0)$ to $\operatorname{SW}\left(2^{\mathrm{N}}-1\right)$ will be ON one at a time depending on the resistance position decoded from the Data Bits. Since the switch is not ideal, there is a $50 \Omega$ wiper resistance, $\mathrm{R}_{\mathrm{W}}$. Wiper resistance is a function of supply voltage and temperature. The lower the supply voltage, the higher the wiper resistance. Similarly, the higher the temperature, the higher the wiper resistance. $\mathrm{R}_{\mathrm{W}}$ is the sum of the resistance of SW(D) + SWB from Wiper-to-B terminals Users should be aware of the contribution of the wiper resistance when accurate prediction of the output resistance is needed.


Figure 9. Equivalent RDAC structure

Table 5. Nominal individual segment resistor values

| Device <br> Resolution | $25 \mathrm{~K} \Omega$ <br> Version | $250 \mathrm{~K} \Omega$ <br> Version |
| :--- | :---: | :---: |
| 10 -Bit | $24.4 \Omega$ | $244 \Omega$ |

## CALCULATIING THE PROGRAMMABLE RESISTANCE

The nominal full scale resistance of the RDAC between terminals W -and-B, $\mathrm{R}_{\text {WB_ }- \text { ss }}$, are available with $25 \mathrm{~K} \Omega$ and $250 \mathrm{~K} \Omega$ with 1024 positions (10-bit resolution). The final digits of the part number determine the nominal resistance value, e.g., $25 \mathrm{~K} \Omega$ $=25 ; 250 \mathrm{~K} \Omega=250$.

The 10-bit data word in the RDAC latch is decoded to select one of the 1024 possible settings. The following discussion describes the calculation of resistance $\mathrm{R}_{\mathrm{WB}}(\mathrm{D})$ at different codes of a $25 \mathrm{~K} \Omega$ part. The wiper first connection starts at the B terminal for data $000_{\mathrm{H}}$. $\mathrm{R}_{\mathrm{WB}}$ is $50 \Omega$ because of the wiper resistance and it is independent to the full-scale resistance. The second connection is the first tap point where $\mathrm{R}_{\mathrm{wB}}(1)$ becomes $24.4 \Omega+50=74.4 \Omega$ for data $01_{\mathrm{H}}$. The third connection is the next tap point representing $R_{\mathrm{WB}}(2)=48.8+50=98.8 \Omega$ for data $02_{\mathrm{H}}$ and so on. Each LSB data value increase moves the wiper up the resistor ladder until the last tap point is reached at $\mathrm{R}_{\mathrm{WB}}(1023)=25026 \Omega$. See Figure 9 for a simplified diagram of the equivalent RDAC circuit.


Figure 10. $\mathrm{R}_{\mathrm{WB}}(\mathrm{D})$ vs Code
The general equation, which determines the programmed output resistance between Wx and Bx , is:

$$
\begin{equation*}
R_{W B}(D)=\frac{D}{2^{N}} \cdot R_{W B_{-} F S}+R_{W} \tag{1}
\end{equation*}
$$

Where D is the decimal equivalent of the data contained in the RDAC register, $2^{\mathrm{N}}$ is the number of steps, $\mathrm{R}_{\text {WB_FS }}$ is the full scale resistance between terminals W-and-B, and $\mathrm{R}_{\mathrm{w}}$ is the wiper resistance.

For example, the following output resistance values will be set for the following RDAC latch codes (applies to $\mathrm{R}_{\text {wB_rs }}=25 \mathrm{~K} \Omega$ programmable resistors):

| D <br> $(\mathrm{DEC})$ | $\mathrm{R}_{\mathrm{WB}}{ }^{(\mathrm{D})}$ <br> $(\Omega)$ | Output State |
| :--- | :--- | :--- |
|  |  |  |
| 1023 | 25026 | Full-Scale |
| 512 | 12550 | Mid-Scale |
| 1 | 74.4 | 1 LSB |
| 0 | 50 | Zero-Scale (Wiper contact resistance) |

## Nonvolatile Memory Programmable Resistors

Note that in the zero-scale condition a finite wiper resistance of $50 \Omega$ is present. Care should be taken to limit the current flow between W and B in this state to no more than 20 mA to avoid degradation or possible destruction of the internal switches.

The typical distribution of full scale $\mathrm{R}_{\mathrm{WB}}$ from channel-tochannel matches to $\pm 0.2 \%$ within the same package. Device to device matching is process lot dependent with the worst case of $\pm 30 \%$ variation. On the other hand, the change in $\mathrm{R}_{\text {WB }}$ with temperature has a $35 \mathrm{ppm} /{ }^{\circ} \mathrm{C}$ temperature coefficient.

## TEST CIRCUITS

Figures 10 to 12 show some of the test conditions used in the product specification table.


Figure 10. Resistor Position Nonlinearity Error (Rheostat Operation; RINL, R-DNL)


Figure 11. Incremental ON Resistance Test Circuit


Figure 12. Common Mode Leakage current test circuit

## PRELIMINARY TECHNICAL DATA

## Nonvolatile Memory Programmable Resistors

## PROGRAMMING EXAMPLES

The following programming examples illustrate typical sequence of events for various features of the ADN2850. Users should refer to Table 2 for the instructions and data word format. The Instruction numbers, addresses, and data appearing at SDI and SDO pins are based in hexadecimal in the following examples.

| $\underline{\text { SDI }}$ | $\underline{\text { SDO }}$ | $\underline{\text { Action }}$ |
| :--- | :--- | :--- |
| $\mathrm{B} 00100_{\mathrm{H}}$ | $\mathrm{XXXXXX}_{\mathrm{H}}$ | Loads data $100_{\mathrm{H}}$ into RDAC1 register, Wiper <br> W1 moves to $1 / 4$ full-scale position |
| $\mathrm{B} 10200_{\mathrm{H}}$ | $\mathrm{B} 00100_{\mathrm{H}}$ | Loads data $200_{\mathrm{H}}$ into RDAC2 register, Wiper 2 <br> moves to $1 / 2$ full-scale position |

Example 1. Set two programmable resistors to independent data

| SDI | SDO | Action |
| :---: | :---: | :---: |
| B00100 ${ }_{\text {H }}$ | XXXXX | Loads W1 mo |
| $\mathrm{E}^{\text {OXXXX }}$ H | B00100 ${ }_{\text {H }}$ | Increm |
| E0XXXX ${ }_{\text {H }}$ | E0XXXX | Increme |
| Continue un | til desired | iper pos |
| $20 \mathrm{XXXX}_{H}$ | XXXXXX | Saves R |
| Optionally | ie WP to C | to pro |

Example 2. Incrementing one programmable resistor followed by storing the wiper setting to EEMEM

| EEMEM values for RDACs can be restored by |  |  |
| :---: | :---: | :---: |
| Power On or |  |  |
| Strobing PR pin or |  |  |
| Programming shown below |  |  |
| SDI | SDO | Action |
| $10 \mathrm{XXXX}_{\mathrm{H}}$ | XXXXXX $_{\text {H }}$ | Restores EEMEM1 value to RDAC1 register |
| $00 \mathrm{XXXX}_{H}$ | $10 \mathrm{XXXXX}{ }_{H}$ | NOP. Recommended step to minimize power consumption |
| $8 \mathrm{XXXXX}_{\mathrm{H}}$ | 00 XXXX H | Restores EEMEM1 and EEMEM2 values to RDAC1 and RDAC2 registers respectively |

Example 3. Restoring EEMEM values to RDAC registers

| $\underline{\text { SDI }}$ | $\underline{\text { SDO }}$ | $\underline{\text { Action }}$ |
| :--- | :--- | :--- |
| ${\mathrm{C} 0 X X X X_{H}}$ | $\mathrm{XXXXXX}_{\mathrm{H}}$ | Moves wiper \#1 to double the present data <br> contained in RDAC1 register |
| $\mathrm{C1XXXX}_{\mathrm{H}}$ | $\mathrm{C} 0 \mathrm{CXXX}_{\mathrm{H}}$ | Moves wiper \#2 to double the present data <br> contained in RDAC2 register. |

Example 4. Using Left shift by one to increment +6 dB steps

| $\underline{\text { SDI }}$ | $\underline{\text { SDO }}$ | $\underline{\text { Action }}$ |
| :--- | :--- | :--- |
| $32 \mathrm{AAAA}_{\mathrm{H}}$ | $\mathrm{XXXXXX}_{\mathrm{H}}$ | Stores data AAAA <br> location USER1 (Allowable to address in 13 <br> locare EEMEM <br> locations with maximum 16-bits of Data) |
| $335555_{\mathrm{H}}$ | $32 \mathrm{AAAA}_{\mathrm{H}}$ | Stores data 5555 <br> location USER2. (Allowable to address 13 <br> locations with maximum 16-bits of Data) |

Example 5. Storing additional user data in EEMEM

| $\underline{\text { SDI }}$ | $\underline{\text { SDO }}$ | $\underline{\text { Action }}$ |
| :--- | :--- | :--- |
| $92 \mathrm{XXXX}_{H}$ | $\mathrm{XXXXXX}_{\mathrm{H}}$ | Prepares data read from USER1 location |
| $00 \mathrm{XXXX}_{\mathrm{H}}$ | $92 \mathrm{AAAA}_{\mathrm{H}}$ | NOP instruction \#0 sends 24-bit word out of <br> SDO where the last 16 bits contain the <br> contents of USER1 location. NOP <br> command insures device returns to idle <br> power dissipation state |

Example 6. Reading back data from various memory locations

| $\underline{\text { SDI }}$ | $\underline{\text { SDO }}$ | $\underline{\text { Action }}$ |
| :--- | :--- | :--- |
| $\mathrm{B} 00200_{\mathrm{H}}$ | $\mathrm{XXXXXX}_{\mathrm{H}}$ | Sets RDAC1 to mid-scale |
| $\mathrm{C} 0 \mathrm{XXXX}_{\mathrm{H}}$ | $\mathrm{B} 00200_{\mathrm{H}}$ | Doubles RDAC1 from mid-scale to full <br> scale |
| $\mathrm{A} 0 \mathrm{XXXX}_{\mathrm{H}}$ | $\mathrm{C} 0 X X X X_{H}$ | Prepares reading wiper setting from RDAC1 <br> register |
| $\mathrm{XXXXXX}_{\mathrm{H}}$ | ${\mathrm{A} 003 \mathrm{FF}_{\mathrm{H}}}^{l}$Readback full scale value from RDAC1 <br> register. |  |

Example 7. Reading back wiper setting
Analog Devices offers a user friendly ADN2850EVAL evaluation kit and it can be controlled by a personal computer through the printer port.

Nonvolatile Memory Programmable Resistors
ADN2850

## APPLICATIONS

Optical Transmitter Calibration with ADN2841
Together with the multi-rate 2.7 Gbps Laser Diode Driver ADN2841, the ADN2850 forms an optical supervisory system where the dual programmable resistors can be used to set the laser average optical power and extinction ratio, see Figure 13. ADN2850 is particularly ideal for the optical parameter settings because of its high resolution and superior temperature coefficient characteristics.

The ADN2841 is a 2.7 Gbps laser diode driver that utilizes a unique control algorithm to manage both the laser average power and extinction ratio after the laser initial factory calibration. It stabilizes the laser data transmission by continuously monitoring its optical power, and correcting the variations caused by temperature and the laser degradation over time. In ADN2841, the $\mathrm{I}_{\text {MPD }}$ monitors the laser diode current. Through its dual loop Power and Extinction Ratio control, calibrated by ADN2850, the internal driver controls the bias current $\mathrm{I}_{\text {BIAS }}$ and consequently the average power. It also regulates the modulation current, $\mathrm{I}_{\text {MODP }}$ by changing the modulation current linearly with slope efficiency. Any changes in the laser threshold current or slope efficiency are therefore compensated. As a result, this optical supervisory system minimizes the laser characterization efforts and therefore enables designers to apply comparable lasers provided from multiple sources.


Figure 13. Optical Supervisory System

## Incoming Optical Power Monitoring

ADN2850 comes with a pair of matched diode-connected PNPs, $\mathrm{Q}_{1}$ and $\mathrm{Q}_{2}$, which can be used to configure an incoming optical power monitoring function. Figure 14 shows such conceptual circuit. With a reference current source, an instrumentation amplifier, and a logarithmic amplifier, this feature can be used to monitor the optical power by knowing the DC average photo diode current from the following properties:


Figure 14. Conceptual Incoming Optical Power Monitoring Circuit.
$V_{1}=V_{B E 1}=V_{T} \ln \frac{I_{C 1}}{I_{S 1}}$
$V_{2}=V_{B E 2}=V_{T} \ln \frac{I_{C 2}}{I_{S 2}}$

Note $\mathrm{I}_{\mathrm{C} 1}=\alpha_{1}{ }^{*} \mathrm{I}_{\mathrm{PD}}, \mathrm{I}_{\mathrm{C} 2}=\alpha_{2} * \mathrm{I}_{\mathrm{REF}}$. Since $\mathrm{Q}_{1}$ and $\mathrm{Q}_{2}$ are matched, therefore $\alpha_{1}$ equals $\alpha_{2}$ and $\mathrm{I}_{\mathrm{S} 1}$ equals $\mathrm{I}_{\mathrm{S} 2}$. Combining equations 2 and 3 yields
$V_{1}-V_{2}=V_{T} \ln \left(\frac{I_{P D}}{I_{R E F}}\right)$
Where $\mathrm{I}_{\mathrm{S} 1}$ and $\mathrm{I}_{\mathrm{S} 2}$ are saturation current
$\mathrm{V}_{1}, \mathrm{~V}_{2}$ are $\mathrm{V}_{\mathrm{BE}}$, base-emitted voltages of the diode-connector transistors
$\mathrm{V}_{\mathrm{T}}$ is the thermal voltage which is equal to $\mathrm{k} * \mathrm{~T} / \mathrm{q} . \mathrm{V}_{\mathrm{T}}=26 \mathrm{mV}$ at $25^{\circ} \mathrm{C}$
$\mathrm{k}=$ Boltzmann's constant $=1.38 \mathrm{E}-23$ joules/kelvin
$\mathrm{q}=$ electron charge $=1.6 \mathrm{E}-19$ coulomb
$\mathrm{T}=$ temperature in kelvin
IPD $=$ photo diode current
$\mathrm{I}_{\text {REF }}=$ reference current
With the final logarithmic amplification, the output voltage represents the average incoming optical power. The output voltage of the log stage does not have to be accurate from device to device as the responsivity of the photo diode will change. However, temperature compensation and the aging stability of the photo diode may be required. The user may also calibrate the log amp using two values of input optical power to give an offset and gradient values. This negates the need for a true log base 10 conversion.

## Resistance Scaling

ADN2850 offers either $25 \mathrm{~K} \Omega$ or $250 \mathrm{~K} \Omega$ full scale resistance. For users who need lower resistance and still maintain the numbers of step adjustment, they can parallel multiple devices. Figure 15 shows a simple scheme of paralleling both channel of the RDACs. In order to adjust half of the resistance linearly per step, users need to program the RDACs coherently with the same settings and tie the terminals as shown. Much lower
resistance can also be achieved by paralleling a discrete resistor as shown in Figure 16. The equivalent resistance at a given setting is approximated as

$$
\begin{equation*}
R_{e q}=\frac{D \cdot R_{W B_{-} F S}+51200}{D \cdot R_{W B_{-} F S}+51200+1024 \cdot R} \tag{5}
\end{equation*}
$$



Figure 15. Reduce Resistance by half with linear adjustment characteristics


Figure 16. Resistor Scaling with log adjustment characteristics
In this approach, the adjustment is not linear but logarithmic. Users should also be aware the need for tolerance matching as well as temperature coefficient matching of the components.

## BASIC RDAC SPICE MODEL



Figure 17. RDAC Circuit Simulation Model for RDAC $=25 \mathrm{k} \Omega$

The internal parasitic capacitances and the external capacitive loads dominate the ac characteristics of the RDACs. A general parasitic simulation model is shown in Figure 7. Listing I provides a macro model netlist for the $25 \mathrm{k} \Omega$ RDAC:

Listing I. Macro Model Net List for RDAC
.PARAM D=1024, RDAC=25E3
*
.SUBCKT RDAC (W,B)
*
RWB W B \{D/1024*RDAC+50\}
CW W $080 \mathrm{E}-12$
CB B $08 \mathrm{E}-12$
*
.ENDS RDAC

ADN2850 - Typical Performance Characteristics


TPC 2 - Supply Current in Storing Data to $\mathrm{E}^{2} \mathrm{MEM}$


TPC 3 - Supply Current in Retreiving Data from $E^{2}$ MEM

Dimensions shown in inches and (mm)


## PRELIMINARY TECHNICAL DATA

## Nonvolatile Memory Programmable Resistors

ADN2850

## 16-Lead LFCSP 5mm x 5mm (CP-16)




ADN2850 has 16 pins.
Drawing above illustrates a generic LFCSP package outline only. Please see table for details

FOR ODD TERMINAL/SIDE
FQR EVEN TERMINAL/SIDE


| $\begin{array}{\|c\|} \hline S_{Y} \\ Y_{M} \\ M \\ B_{0} \\ 0 \\ \hline \end{array}$ | $\begin{gathered} \text { COMMON } \\ \text { DIMENSIONS } \end{gathered}$ |  |  | ${ }^{N_{O_{T}}}$ |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |
|  | MIN. | NOM | MAX |  |
| A | - | 0.85 | 1.00 |  |
| A1 | 0.00 | 0.01 | 0.05 | 11 |
| A2 | - | 0.65 | 0.80 |  |
| A3 |  | 20 RE |  |  |
| D |  | . 00 BS |  |  |
| D1 |  | 75 BS |  |  |
| E |  | . 00 BS |  |  |
| E1 |  | 75 BS |  |  |
| $\theta$ |  |  | $12^{\circ}$ |  |
| P | 0.24 | 0.42 | 0.60 |  |
| R | 0.13 | 0.17 | 0.23 |  |


| SYMBOLS |  | D2 |  |  | E2 |  |  | NOTE |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | NOM | MAX | MIN | NOM | MAX |  |
| EXPOSED PAD | A | 2.95 | 3.10 | 3.25 | 2.95 | 3.10 | 3.25 |  |
| VARIATIONS | B | 2.55 | 2.70 | 2.85 | 2.55 | 2.70 | 2.85 |  |
|  | C | 3.15 | 3.30 | 3.45 | 3.15 | 3.30 | 3.45 |  |

VOTES: 1. DIE THICKNESS ALLOWABLE IS 0.305 mm MAXIMUM(. 012 INCHES MAXIMUM)
2. DIMENSIONING \& TOLERANCES CONFORM TO ASME Y14.5M. - 1994.
3. N IS THE NUMBER OF TERMINALS

Nd IS THE NUMBER OF TERMINALS IN X-DIRECTION \&
4. DIMENSION b APPLIES TO PLATED TERMINAL AND IS MEASURED

BETWEEN 0.20 AND 0.25 mm FROM TERMINAL TIP.
5. THE PIN \#1 IDENTIFIER MUST be EXISTED ON THE TOP SURFACE OF THE

PACKAGE BY USING INDENTATION MARK OR OTHER FEATURE OF PACKAGE BODY.
6. EXACT SHAPE AND SIZE OF THIS FEATURE IS OPTIONAL.
7. ALL DIMENSIONS ARE IN MLLIMETERS.
8. THE SHAPE SHOWN ON FOUR CORNERS ARE NOT ACTUAL $1 / 0$
9. PACKAGE WARPAGE MAX 0.05 mm .
10. APPLIED FOR EXPOSED PAD AND TERMINALS

ExClude embedoding part of EXPosed

- PAD FROM MEASURING.
(2. JEDEC MO-220 DESIGNATOR


[^0]:    Notes:

    1. The term nonvolatile memory and EEMEM are used interchangebly
    2. The term programmable resistor and RDAC are used interchangebly
